home *** CD-ROM | disk | FTP | other *** search
/ Supercompiler 1997 / SUPERCOMPILER97.iso / Delphi 3.0 / DATA.Z / htcoledt.pas < prev    next >
Encoding:
Pascal/Delphi Source File  |  1997-01-29  |  9.6 KB  |  353 lines

  1. unit HTColEdt;
  2.  
  3. interface
  4.  
  5. uses
  6.   Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  7.   Colnedit, Menus, StdCtrls, ExtCtrls, OleCtrls, ISP3, DBWeb, DsgnIntf,
  8.   DB, TypInfo, ComCtrls;
  9.  
  10. const
  11.   HTMLColors: array[0..15] of string =
  12.     ('Aqua', 'Black', 'Blue', 'Fushsia', 'Gray', 'Green', 'Lime', 'Maroon',
  13.      'Navy', 'Olive', 'Purple', 'Red', 'Silver', 'Teal', 'White', 'Yellow');
  14.   CM_POSTCHANGE = WM_USER + $200;
  15.  
  16. type
  17.   THTMLTableEditor = class(TCollectionEditor)
  18.     HTML: THTML;
  19.     Panel2: TPanel;
  20.     GroupBox1: TGroupBox;
  21.     Label1: TLabel;
  22.     TableBorderEdit: TEdit;
  23.     CellPaddingEdit: TEdit;
  24.     CellSpacingEdit: TEdit;
  25.     TableWidthEdit: TEdit;
  26.     TableAlignCombo: TComboBox;
  27.     TableBgColorCombo: TComboBox;
  28.     AddAllFields: TButton;
  29.     Addallfields1: TMenuItem;
  30.     procedure FormCreate(Sender: TObject);
  31.     procedure HTMLDoRequestDoc(Sender: TObject; const URL: WideString;
  32.       const Element: HTMLElement; const DocInput: DocInput;
  33.       var EnableDefault: WordBool);
  34.     procedure TableDataChanged(Sender: TObject);
  35.     procedure TableDataKeyPress(Sender: TObject; var Key: Char);
  36.     procedure TableDataExit(Sender: TObject);
  37.     procedure FormDestroy(Sender: TObject);
  38.     procedure TableDataClicked(Sender: TObject);
  39.     procedure AddAllFieldsClick(Sender: TObject);
  40.   private
  41.     FHTTPDSHandlerEditor: TDSTableProducerEditor;
  42.     FModified: Boolean;
  43.     procedure CMPostChange(var M: TMessage); message CM_POSTCHANGE;
  44.     procedure PostChange;
  45.     procedure UpdateTableAttributes;
  46.     procedure UpdateTableComponent;
  47.   public
  48.     procedure Activated; override;
  49.     procedure FormModified; override;
  50.     procedure UpdateHTMLView;
  51.     function GetDataSet: TDataSet;
  52.     procedure SetAddAllFieldsState;
  53.   end;
  54.  
  55.   THTMLDSTableProducerEditor = class(TDSTableProducerEditor)
  56.   private
  57.     FHTMLTableEditor: THTMLTableEditor;
  58.   public
  59.     constructor Create(HTMLTableEditor: THTMLTableEditor;
  60.       DSTableProducer: TDSTableProducer);
  61.     destructor Destroy; override;
  62.     procedure Changed; override;
  63.     procedure PostChange; override;
  64.     property HTMLTableEditor: THTMLTableEditor read FHTMLTableEditor;
  65.   end;
  66.  
  67. procedure ShowHTMLTableEditor(ADesigner: TDesigner;
  68.   DSTableProducer: TDSTableProducer; const PropertyName: string);
  69.  
  70. implementation
  71.  
  72. uses HTTPApp, WebConst, NetConst;
  73.  
  74. {$R *.DFM}
  75.  
  76. procedure ShowHTMLTableEditor(ADesigner: TDesigner;
  77.   DSTableProducer: TDSTableProducer; const PropertyName: string);
  78. var
  79.   Editor: THTMLDSTableProducerEditor;
  80.   HTMLTableEditor: THTMLTableEditor;
  81. begin
  82.   if DSTableProducer.Editor <> nil then
  83.   begin
  84.     Editor := THTMLDSTableProducerEditor(DSTableProducer.Editor);
  85.     HTMLTableEditor := Editor.HTMLTableEditor;
  86.     HTMLTableEditor.Show;
  87.   end else
  88.   begin
  89.     HTMLTableEditor := THTMLTableEditor(ShowCollectionEditorClass(ADesigner,
  90.       THTMLTableEditor, DSTableProducer, DSTableProducer.Columns, PropertyName));
  91.     THTMLDSTableProducerEditor.Create(HTMLTableEditor, DSTableProducer);
  92.   end;
  93. end;
  94.  
  95. { THTMLDSTableProducerEditor }
  96.  
  97. constructor THTMLDSTableProducerEditor.Create(HTMLTableEditor: THTMLTableEditor;
  98.   DSTableProducer: TDSTableProducer);
  99. begin
  100.   inherited Create(DSTableProducer);
  101.   FHTMLTableEditor := HTMLTableEditor;
  102.   FHTMLTableEditor.FHTTPDSHandlerEditor := Self;
  103. end;
  104.  
  105. destructor THTMLDSTableProducerEditor.Destroy;
  106. begin
  107.   if FHTMLTableEditor <> nil then
  108.     FHTMLTableEditor.Free;
  109.   inherited Destroy;
  110. end;
  111.  
  112. procedure THTMLDSTableProducerEditor.Changed;
  113. begin
  114.   if FHTMLTableEditor.StateLock = 0 then
  115.   begin
  116.     FHTMLTableEditor.UpdateListBox;
  117.     FHTMLTableEditor.UpdateHTMLView;
  118.     FHTMLTableEditor.UpdateTableAttributes;
  119.   end;
  120. end;
  121.  
  122. procedure THTMLDSTableProducerEditor.PostChange;
  123. begin
  124.   if FHTMLTableEditor.StateLock = 0 then
  125.     FHTMLTableEditor.PostChange;
  126. end;
  127.  
  128. { THTMLTableEditor }
  129.  
  130. procedure THTMLTableEditor.Activated;
  131. begin
  132.   if StateLock = 0 then
  133.   begin
  134.     inherited;
  135.     UpdateHTMLView;
  136.     UpdateTableAttributes
  137.   end;
  138. end;
  139.  
  140. procedure THTMLTableEditor.AddAllFieldsClick(Sender: TObject);
  141. var
  142.   Result, I: Integer;
  143.   DataSet: TDataSet;
  144. begin
  145.   Result := idYes;
  146.   if (Collection.Count > 0) and
  147.     ((Collection as THTMLTableColumns).State = csCustom) then
  148.     Result := MessageDlg(sDeleteColumnsQuestion, mtConfirmation, mbYesNoCancel, 0);
  149.  
  150.   LockState;
  151.   try
  152.     case Result of
  153.       idCancel: Exit;
  154.       idYes: (Collection as THTMLTableColumns).RebuildColumns;
  155.       idNo:
  156.         begin
  157.           DataSet := GetDataSet;
  158.           if DataSet <> nil then
  159.             with Dataset do
  160.             begin
  161.               Collection.BeginUpdate;
  162.               try
  163.                 for I := 0 to FieldCount-1 do
  164.                   THTMLTableColumns(Collection).Add.FieldName := Fields[I].FieldName;
  165.               finally
  166.                 Collection.EndUpdate;
  167.               end;
  168.               for I := 0 to Collection.Count - 1 do
  169.                 THTMLTableColumns(Collection).Items[I].Update;
  170.             end;
  171.         end;
  172.     end;
  173.   finally
  174.     UnlockState;
  175.     SetSelection;
  176.     Designer.Modified;
  177.   end;
  178. end;
  179.  
  180. procedure THTMLTableEditor.CMPostChange(var M: TMessage);
  181. begin
  182.   inherited;
  183.   UpdateListBox;
  184.   UpdateTableAttributes;
  185.   UpdateHTMLView;
  186. end;
  187.  
  188. procedure THTMLTableEditor.FormModified;
  189. begin
  190.   // DSTableProducerEditor will handle all updates
  191.   inherited FormModified;
  192.   SetAddAllFieldsState;
  193. end;
  194.  
  195. procedure THTMLTableEditor.UpdateHTMLView;
  196. begin
  197.   with Component as TDSTableProducer do
  198.     if (DataSet <> nil) and (StateLock = 0)  then
  199.       Self.HTML.RequestDoc('file://foobar');
  200. end;
  201.  
  202. procedure THTMLTableEditor.FormCreate(Sender: TObject);
  203. var
  204.   I: Integer;
  205. begin
  206.   inherited;
  207.   for I := Ord(Low(THTMLAlign)) to Ord(High(THTMLALign)) do
  208.     TableAlignCombo.Items.Add(GetEnumName(TypeInfo(THTMLAlign), I));
  209.   for I := Low(HTMLColors) to High(HTMLColors) do
  210.     TableBgColorCombo.Items.Add(HTMLColors[I]);
  211. end;
  212.  
  213. procedure THTMLTableEditor.FormDestroy(Sender: TObject);
  214. begin
  215.   inherited;
  216.   if (FHTTPDSHandlerEditor <> nil) then
  217.     with THTMLDSTableProducerEditor(FHTTPDSHandlerEditor) do
  218.     begin
  219.       FHTMLTableEditor := nil;
  220.       Free;
  221.     end;
  222. end;
  223.  
  224. function THTMLTableEditor.GetDataSet: TDataSet;
  225. begin
  226.   if (Component <> nil) and (Component is TDSTableProducer) then
  227.     Result := TDSTableProducer(Component).DataSet
  228.   else Result := nil;
  229. end;
  230.  
  231. procedure THTMLTableEditor.HTMLDoRequestDoc(Sender: TObject;
  232.   const URL: WideString; const Element: HTMLElement;
  233.   const DocInput: DocInput; var EnableDefault: WordBool);
  234. begin
  235.   inherited;
  236.   with Component as TDSTableProducer do
  237.   begin
  238.     LockState;
  239.     try
  240.       BeginUpdate;
  241.       try
  242.         if DataSet.Active then DataSet.First;
  243.         DocInput.SetData(WideString(
  244.           Header.Text +
  245.           HTMLTable(DataSet, TDSTableProducer(Component), MaxRows) +
  246.           Footer.Text));
  247.       finally
  248.         EndUpdate;
  249.       end;
  250.     finally
  251.       UnlockState;
  252.     end;
  253.   end;
  254. end;
  255.  
  256. procedure THTMLTableEditor.PostChange;
  257. var
  258.   M: TMsg;
  259. begin
  260.   if not PeekMessage(M, Handle, CM_POSTCHANGE, CM_POSTCHANGE, PM_NOREMOVE) then
  261.     PostMessage(Handle, CM_POSTCHANGE, 0, 0);
  262. end;
  263.  
  264. procedure THTMLTableEditor.SetAddAllFieldsState;
  265. var
  266.   DataSet: TDataSet;
  267. begin
  268.   DataSet := GetDataSet;
  269.   AddAllFields.Enabled := (Dataset <> nil) and (Dataset.FieldCount > 0);
  270.   AddAllFields1.Enabled := AddAllFields.Enabled;
  271. end;
  272.  
  273. procedure THTMLTableEditor.TableDataChanged(Sender: TObject);
  274. begin
  275.   inherited;
  276.   FModified := True;
  277. end;
  278.  
  279. procedure THTMLTableEditor.TableDataClicked(Sender: TObject);
  280. begin
  281.   inherited;
  282.   UpdateTableComponent;
  283. end;
  284.  
  285. procedure THTMLTableEditor.TableDataKeyPress(Sender: TObject;
  286.   var Key: Char);
  287. begin
  288.   inherited;
  289.   if FModified and (Key in [#13, #27]) then
  290.   try
  291.     if Key = #13 then
  292.     begin
  293.       UpdateTableComponent;
  294.       if Sender is TEdit then
  295.         TEdit(Sender).SelectAll
  296.       else if Sender is TComboBox then
  297.         if TComboBox(Sender).Style = csDropDown then
  298.           TComboBox(Sender).SelectAll;
  299.     end else if Key = #27 then
  300.       UpdateTableAttributes;
  301.   finally
  302.     FModified := False;
  303.     Key := #0;
  304.   end else FormKeyPress(Sender, Key);
  305. end;
  306.  
  307. procedure THTMLTableEditor.TableDataExit(Sender: TObject);
  308. begin
  309.   inherited;
  310.   if FModified then
  311.   try
  312.     UpdateTableComponent;
  313.   finally
  314.     FModified := False;
  315.   end;
  316. end;
  317.  
  318. procedure THTMLTableEditor.UpdateTableAttributes;
  319. begin
  320.   with (Component as TDSTableProducer).TableAttributes do
  321.   begin
  322.     TableAlignCombo.ItemIndex := Ord(Align);
  323.     TableBgColorCombo.Text := BgColor;
  324.     TableBorderEdit.Text := IntToStr(Border);
  325.     TableWidthEdit.Text := IntToStr(Width);
  326.     CellPaddingEdit.Text := IntToStr(CellPadding);
  327.     CellSpacingEdit.Text := IntToStr(CellSpacing);
  328.   end;
  329. end;
  330.  
  331. procedure THTMLTableEditor.UpdateTableComponent;
  332. begin
  333.   with Component as TDSTableProducer do
  334.   begin
  335.     BeginUpdate;
  336.     try
  337.       if (TableAlignCombo.ItemIndex >= Ord(Low(THTMLAlign))) and
  338.         (TableAlignCombo.ItemIndex <= Ord(High(THTMLAlign))) then
  339.         TableAttributes.Align := THTMLAlign(TableAlignCombo.ItemIndex);
  340.       TableAttributes.Border := StrToIntDef(TableBorderEdit.Text, -1);
  341.       TableAttributes.BgColor := TableBgColorCombo.Text;
  342.       TableAttributes.CellPadding := StrToIntDef(CellPaddingEdit.Text, -1);
  343.       TableAttributes.CellSpacing := StrToIntDef(CellSpacingEdit.Text, -1);
  344.       TableAttributes.Width := StrToIntDef(TableWidthEdit.Text, 100);
  345.     finally
  346.       FModified := False;
  347.       EndUpdate;
  348.     end;
  349.   end;
  350. end;
  351.  
  352. end.
  353.